<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/vue.js"></script>
    <style>
        li{list-style: none;}
    </style>
</head>
<body>
    <div id="app">
        <button @click="sortList">点击排序</button>
        <button @click="addEleToList">点击新增</button>
        <ul>
            <li v-for="item,index in list" :key="index">
                {{item}}
            </li>
        </ul>

     
    </div>
</body>
<script>
    // v-for 列表渲染
    // 用 v-for 把一个数组对应为一组元素  
    // 我们可以用 v-for 指令基于一个数组来渲染一个列表。v-for 指令需要使用 item in items 形式的特殊语法，其中 items 是源数据数组，而 item 则是被迭代的数组元素的别名。

    // 注意: v-for 不仅可以遍历数组,还可以遍历 对象 数值

    // 当 Vue 正在更新使用 v-for 渲染的元素列表时，它默认使用“就地更新”的策略。如果数据项的顺序被改变，Vue 将不会移动 DOM 元素来匹配数据项的顺序，而是就地更新每个元素，并且确保它们在每个索引位置正确渲染。这个类似 Vue 1.x 的 track-by="$index"。

    // 这个默认的模式是高效的，但是只适用于不依赖子组件状态或临时 DOM 状态 (例如：表单输入值) 的列表渲染输出。

    // 为了给 Vue 一个提示，以便它能跟踪每个节点的身份，从而重用和重新排序现有元素，你需要为每项提供一个唯一 key attribute：

    // 建议尽可能在使用 v-for 时提供 key attribute，除非遍历输出的 DOM 内容非常简单，或者是刻意依赖默认行为以获取性能上的提升。

    // 不要使用对象或数组之类的非基本类型值作为 v-for 的 key。请用字符串或数值类型的值。

   
 

    var vm = new Vue({
        el:"#app",
        data:{
            list:[1,4,7,2,5,8,3,6,9],
        },
        methods: {
            sortList(){
                this.list.sort((a,b)=>a-b);
            },
            addEleToList(){
                var num = Math.round(Math.random()*100);  //随机数值
                var index = Math.floor(Math.random()*this.list.length); // 随机下标

                this.list.splice(index,0,num);


            }

        },
    })






</script>
</html>